Name \_\_\_\_\_

EE3610 Practice Final Exam.

\_\_\_\_\_

Part 1. Short Answer.

- 1. (3 pts) With the IEEE std\_logic\_1164 library, what will the state of a std\_logic signal be if it is simultaneously driven with '0' and 'Z'?
- 2. (3 pts) Describe <u>how</u> VHDL resolves signal conflicts like those in Question 1.

3. (4 pts) Represent 9,375 using 32-bit IEEE floating point (in hexadecimal or binary).

- 4. (4 pts) What number is represented by C0D00000 in 32-bit IEEE floating point?
- 5. (2 pts) (true/false) The 32-bit IEEE floating point representation of infinity is FFFFFF<sub>16</sub>.

- 6. (4 pts) Name two techniques that can be used to test sequential logic circuits
  - (a) \_\_\_\_\_\_(b) \_\_\_\_\_
- (2 pts) The code segment below is most likely to imply (dedicated/distributed) memory (circle one). if clk'event and clk='1' then data\_out <= rom\_array(address); end if;
- 8. (2 pts) (true/false) The original motivation for boundary scan testing was to test for circuit board defects (including soldering defects).
- 9. (3 pts) What is the acronym by which the IEEE/ANSI standard interface for boundary scan testing is commonly known?

<sup>10. (2</sup> pts) (true/false) One of the main advantages of a 1-hot state assignment is that the number of flip-flops is minimized.

11. (6 pts) The VHDL code below purports to implement the 4-bit linear feedback shift register shown in Figure 10-27 of the text. Identify 2 errors.

```
architecture behavioral of LFSR is
    type linear_feedback_shift_register is array (4 downto 1) of bit;
    signal Q: linear_feedback_shift_register;
    signal D1, Y: bit;
begin
    process(clk,rst)
    begin
        if rst='1' then
            Q \le "0000"
        elsif clk'event and clk='1' then
            for i in Q'left(1) to Q'right(1) loop
                 if i = Q'left(1) then
                     Q(i) <= D1;
                 else
                     Q(i) <= Q(i-1);
                 end if;
             end loop;
        end if;
    end process;
    process (Q)
    begin
        if Q(1)='0' and Q(2)='0' and Q(3)='0' then
            Y <= '1';
        end if;
        D1 \le Q(1) \text{ xor } Q(4) \text{ xor } Y;
    end process;
end behavioral;
```

Extra Credit (3 pts): There is a third error in the code above that is particularly subtle. Find it.

Part 2. Problems.

12. In this problem, you are to design a VHDL behavioral model for an ALU that takes two 32-bit inputs A and B, and generates a result, Y, according the opcode and the function table below. (You may ignore carry for all operations, including addition and subtraction.) The entity part is provided on the top of the next page. (a) (8 pts) Write the architecture part. Be sure to add comments.

| opcode | Y                                                      |
|--------|--------------------------------------------------------|
| 000    | А                                                      |
| 001    | В                                                      |
| 010    | A+B                                                    |
| 011    | A – B                                                  |
| 100    | A and B                                                |
| 101    | A or B                                                 |
| 110    | A rotated left by (the least significant 5 bits of) B  |
| 110    | A rotated right by (the least significant 5 bits of) B |

library IEEE; use IEEE.std\_logic\_1164.all; use IEEE.numeric\_std.all;

entity alu32 is

| port ( opcode: in std_logic_vector(2 downto 0); |  |
|-------------------------------------------------|--|
| A, B: in std_logic_vector(31 downto 0);         |  |
| Y: out: std_logic_vector(31 downto 0));         |  |
| end alu32;                                      |  |

- -- opcode as shown in table
- -- 32-bit inputs
- -- 32-bit output

(b) (3 pts) What is the risk of synthesizing an ALU using a behavioral model like this?

\_\_\_\_\_

(c) (3 pts) How could you mitigate the risk that you described in part (b)?

13. Consider the circuit below:



(a) (12 pts) Find a set of test vectors that will test every stuck-at fault. Note: treat  $\bar{c}$  as its own variable, but one that is constrained (in the test vectors) to be the complement of *c*. (e.g. use  $\bar{c}$ 0 to denote  $\bar{c}$  stuck-at-0.)



(b) (8 pts) Write a test bench to test every vector you found in (a). TO GET FULL CREDIT YOU MUST(i) use constant arrays for your input and output vectors, and (ii) check the output of the circuit and generate an error message if it is incorrect.

entity testbench is end testbench;

architecture behavioral of testbench is component foo is port (a, b, c, d, e: in bit; y: out bit); end foo;

signal a, b, c, d, e, f, y: bit;

begin

uut: foo(a,b,c,d,e,y);



Use the 5-stage processor architecture depicted in the figure below for Problem 14.

14. Consider the program below:

| add r1,r1,r3   | ; r1 ← r1 + r3                                            |
|----------------|-----------------------------------------------------------|
| load r2,4(r1)  | ; load r2 with the contents of data memory address [r1+4] |
| and r2,r2,#255 | ; r2 $\leftarrow$ r2 and 011111111 <sub>2</sub>           |
| store r2,8(r1) | ; store r2 at address [r1+8] in data memory               |

(a) (3 pts) Assume a "write-through" register file and the forwarding paths shown in the diagram. Which of these instructions (if any) will stall the pipeline?

(b) (6 pts) Assume all hazards are detected in the decode stage (i.e. an instruction remains in the decode stage until it is safe for it to proceed.) If the first instruction (add r1,r1,r3) is in the fetch stage in cycle 1, complete the table below to show the pipeline stage for each instruction on a given cycle. You may abbreviate a stage with its first letter. (e.g. Write F instead of Fetch).

| Instruction    | Cycle 1 | Cycle 2 | Cycle 3 | Cycle 4 | Cycle 5 | Cycle 6 | Cycle 7 | Cycle 8 | Cycle 9 |
|----------------|---------|---------|---------|---------|---------|---------|---------|---------|---------|
| add r1,r1,r3   | F       | D       | E       | М       | W       |         |         |         |         |
| load r2,4(r1)  | -       |         |         |         |         |         |         |         |         |
| and r2,r2,#255 | -       |         |         |         |         |         |         |         |         |
| store r2,8(r1) | -       |         |         |         |         |         |         |         |         |

(c) (4 pts) The inputs of the ALU in the diagram are labeled a and b. Assume that initially  $R1 = 1234_{16}$ ,  $R3 = 2220_{16}$  and the data memory at address  $3458_{16}$  is  $89AB_{16}$ . State which instruction is in the *execute* stage and what the value of a and b are during each clock cycle given below. (Note: if a pipeline bubble is in the execution stage, write X in each column.)

| Cycle | Instruction  | а    | b    |
|-------|--------------|------|------|
| 3     | add r1,r1,r3 | 1234 | 2220 |
| 4     |              |      |      |
| 5     |              |      |      |
| 6     |              |      |      |
| 7     |              |      |      |

(d) (4 pts) What value is stored to memory by the last instruction in the program (store r2,8(r1)), and at what address is it stored?

Value: \_\_\_\_\_ Address: \_\_\_\_\_ 15. (a) (4 pts) Use Shannon's Decomposition to expand the equation below about the variable A.

$$F = A\overline{B}C\overline{E} + \overline{A}CD\overline{E} + AB\overline{C}\overline{D}E + \overline{B}\overline{C}DE$$

F=\_\_\_\_\_

(b) (10 pts) Use your results from (a) to implement this equation with the logic blocks below. Label inputs A-E, label output F, and draw in the necessary interconnects. Then give the logic function for each block. (Hint. You may not need all the LUTs.)

